package modelo.hibernate.dao;

import java.util.ArrayList;
import java.util.List;

import modelo.entidad.Laboratorio2;
import modelo.hibernate.config.Sesion;

import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.criterion.Restrictions;

public class DaoLaboratorio2 {
	private Sesion sesionPostgres;
	
	public void agregarLaboratorio2(Laboratorio2 dato) throws Exception{
		@SuppressWarnings("static-access")
		Session em = sesionPostgres.openSession();  
         Transaction tx = null;  
         try {    
        	 tx = em.beginTransaction();
              em.save( dato);   
              tx.commit();  
         } catch (Exception e) {  
             tx.rollback();            
             e.printStackTrace();
             throw e;
         } finally {  
             em.close();  
         } 
	}
	
	public void modificarLaboratorio2(Laboratorio2 dato) throws Exception{
		@SuppressWarnings("static-access")
		Session em = sesionPostgres.openSession();  
         Transaction tx = null;  
         try {    
        	 tx = em.beginTransaction();
              em.update(dato);   
              tx.commit();  
         } catch (Exception e) {  
             tx.rollback();            
             e.printStackTrace();
             throw e;
         } finally {  
             em.close();  
         } 
	}
	
	
	
	public void eliminarLaboratorio2(Laboratorio2 dato) throws Exception{		 
		@SuppressWarnings("static-access")
		Session sesion = sesionPostgres.openSession();  
        Transaction tx = null;  
        try {  
            tx = sesion.beginTransaction();  
            sesion.delete(dato);  
            tx.commit();  
           
        } catch (Exception e) {  
            tx.rollback();  
           
            throw new Exception(e.getMessage(), e.getCause());
        } finally {  
            sesion.close();  
        }  
   }
	

	public Laboratorio2 obtenerLaboratorio2(int id) throws Exception{		 
	    @SuppressWarnings("static-access")
		Session sesion = sesionPostgres.openSession();  
            Laboratorio2 dato = null;        
            try{
                dato = (Laboratorio2) sesion.get(Laboratorio2.class, id);
            } catch (Exception e) {  
            e.printStackTrace();
           
            throw new Exception(e.getMessage(),e.getCause());
            }  finally {  
                sesion.close();  
            }  
           
	    return dato;
}
	
	public List<Laboratorio2> obtenerTodos() throws Exception {            
	      
		List<Laboratorio2> datos = new ArrayList<Laboratorio2>();  
	  Session em = sesionPostgres.openSession();  	
        try {  	
	    datos =  (List<Laboratorio2>) em.createCriteria(Laboratorio2.class).list();             
        } catch (Exception e) {             
       
         throw new Exception(e.getMessage(),e.getCause());
        } finally {  
          em.close();  
        } 
       
        return datos; 
	}	

	
	public Laboratorio2 buscarLaboratorio2(String descripcion) throws Exception{
		for (Laboratorio2 u: obtenerTodos() ){
			if (u.getDescripcion().equalsIgnoreCase(descripcion))
				return u;
		}
		return null;					
	}
	
	public void actualizarLaboratorio2(Laboratorio2 dato) throws Exception{

		Session em =  sesionPostgres.openSession();
         Transaction tx = null;  
         try {    
        	 tx = em.beginTransaction();
              em.update(dato);   
              tx.commit();  
         } catch (Exception e) {  
             tx.rollback();            
             e.printStackTrace();
             throw e;
         } finally {  
             em.close();  
         } 
	}
	


}
